/*
给定一个二叉树，判断它是否是高度平衡的二叉树。
本题中，一棵高度平衡二叉树定义为：
一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1 。
递归自底向上
https://leetcode.cn/problems/balanced-binary-tree/
* */
class IsBalancedFromDiToShan {
    public boolean isBalanced(TreeNode root) {
        return length(root)>=0;
    }
    public int length(TreeNode root){
        if(root==null){
            return 0;
        }
        int leftH=length(root.left);
        int rightH=length(root.right);
        if(leftH==-1|| rightH==-1||Math.abs(leftH-rightH)>1){
            return -1;
        }
        return leftH>rightH?leftH+1:rightH+1;
    }
}